Page({
  data: {
    dateLayerVisible: false,
    houseLayerVisible: false,
    houseList: [],
    currentDate: 1675872000000
  },
  openHouseLayer() {
    this.setData({ houseLayerVisible: true })
  },
  closeHouseLayer() {
    this.setData({ houseLayerVisible: false })
  },
  openDateLayer() {
    this.setData({ dateLayerVisible: true })
  },
  closeDateLayer() {
    this.setData({ dateLayerVisible: false })
  },
  async goPassport() {
    // 逐个验证表单的数据
    if (!this.verifyHouse()) return
    if (!this.verifyName()) return
    if (!this.verifyMobile()) return
    // 待提交的数据
    const { houseId, name, gender, mobile, visitDate } = this.data
    console.log(houseId, name, gender, mobile, visitDate)
    // 请求接口
    const { code, data: { id }} = await wx.http.post('visitor', { houseId, name, gender, mobile, visitDate })
    // 检测接口调用结果
    if (code !== 10000) return wx.utils.toast('添加访客失败!')
    wx.reLaunch({
      url: `/visitor_pkg/pages/passport/index?id=${id}`
    })
  },
  // 在页面生成时
  onLoad() {
    // 获取可用房间
    this.getHouse()
  },
  async getHouse() {
    const { code, data: houseList } = await wx.http.get('house')
    if (code !== 10000) return wx.utils.toast()
    this.setData({ houseList })
  },
  getVisitDate({ detail }) {
    // 将时间戳转换为人类时间
    const visitDate = new Date(detail).toLocaleDateString()
    // 更新数据
    this.setData({ visitDate })
    // 完事后关闭日历组件
    this.closeDateLayer()
  },
  selectHouse({ detail }) {
    // 更新数据
    this.setData({
      houseId: detail.id,
      houseInfo: detail.name
    })
  },
  // 建立表单验证规则
  verifyHouse() {
    const valid = this.data.houseId !== ''
    // 验证结果提示
    if (!valid) wx.utils.toast('请选择房屋信息!')
    // 返回验证结果
    return valid
  },
  // 验证业主姓名（必须为汉字）
  verifyName() {
    // 正则表达式
    const reg = /^[\u4e00-\u9fa5]{2,5}$/
    // 验证业主姓名
    const valid = reg.test(this.data.name.trim())
    // 验证结果提示
    if (!valid) wx.utils.toast('请填写真实中文姓名!')
    // 返回验证结果
    return valid
  },
  verifyMobile() {
    // 验证手机号
    const reg = /^[1][3-8][0-9]{9}$/
    const valid = reg.test(this.data.mobile)
    // 验证结果提示
    if (!valid) wx.utils.toast('请填写正确的手机号码!')
    // 返回验证结果
    return valid
  }

})
